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(54) Messaging and status indication for wireless communication devices 



(57) The present invention relates to a wireless 
communication system (100) having a storage device 
(112) for storing a list containing status information and 
identifiers for a plurality of previously identified wireless 
communication devices (102). A processor in a mobile 
communication device can retrieve and store a list con- 
taining status information and identifiers for a plurality of 
previously identified mobile devices from a remote 
server device and display them on the display screen 
thereof. By utilizing subscriber status information a user 



can determine the status of a mobile device associated 
with the intended recipient of a call or message prior to 
any attempt to contact that person. The Interaction 
between the mobile device used by the user and the 
monitored mobile devices can be through a phone call 
or a text message, either of which can be initiated with 
minimal device interaction by using embedded contact 
infomnatlon. 
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Description 

BACKGROU ND OF THE INVEIMTION 

1 . Reld of the Invention 

[0001] The present invention relates to wireless 
communication systems and, more particularly, to a 
wireless communication system utilizing subscriber sta- 
tus information to enable a user to determine the status 
of a mobile device associated with the intended recipi- 
ent of a call or message prior to any attempt to contact 
that person. 

2. Description of the Related Art 

[0002] There are already several hundred million 
subscribers to wireless communication services 
throughout the world. With this proliferation of wireless 
communications, it is becoming more and more likely 
that parties will interact with one another in instances 
where the only means of communication for one or both 
parties is through wireless communication systems. 
Wireless communication refers to the situation In which 
at least one party is making use of a portable, wireless 
two-way interactive communication device and a wire- 
less network. Portable, wireless two-way interactive 
communication devices can, tor example, include per- 
sonal digital assistants (PDAs), two-way pagers, palm- 
sized computers and mobile phones. 
[0003] Wireless carriers operate wireless networks 
that support wireless communications between parties. 
These carriers, such as providers of cellular phone or 
pager services, typically have knowledge of the activa- 
tion status (e.g. on or off) of serviced devices. Wireless 
earners also tend to know the location of the portable 
wireless two-way interactive communication devices of 
its subscribers, at least within Its range of coverage. 
This activation and location information may be used by 
wireless carriers for the purpose of centrally managing 
calls to and from its subscribers (e.g., tracking position 
or automatic call redirection). 

[0004] Often one or both of the parties want to com- 
municate with each other in real- time. Such real-time 
communications is offered by portable wireless two-way 
interactive devices, referred to as mobile devices 
herein, such as mobile or cellular phones and two-way 
pagers. However, even when one or both parties have 
mobile devices, real-time communications between 
them are available only when their mobile devices are In 
a mode of operation capable of receiving incoming com- 
munfcations. Hence, when one attempts to reach 
another party having a mobile devfee, which may be 
powered off (also refen-ed to as off-line), the call does 
not go through. Instead, the calling party may hear a 
message to the effect of "the subscriber you have called 
is either out of range or the phone off." In this situation, 
the calling party has wasted time trying to contact an 



inactive mobile device. From the perspective of the car- 
riers, their limited resources (e.g. channel capacity) 
have been utilized in an inefficient and unprofitable (i.e. 
calls to inactive devices are generally not billed) manner 
5 to contact an inactive mobile device. 

[0005] It would be desirable to have apparatuses 
and methods which facilitate obtaining and using infor- 
mation regarding mobile device status infomiation for 
mobile devices of Interest. 

10 

SUMMARY OF THE INVENTION 

[0006] The present invention is directed to a com- 
munication system that makes available and utilizes sta- 

15 tus information so that users of the communication 
system are informed about the status of monitored 
mobile devices of interest before attempting to interact 
with those mobile devices. Subscribers having this serv- 
ice will have available near real-time infomnation as to 

20 which associates (i.e. individuals or groups of interest to 
the subscriber for purposes of communication) may be 
contacted immediately and which associates are una- 
vailable. Additional infomnation relating to why an asso- 
ciate of interest is unavailable (e.g. "I'm in a meeting") or 

25 when they plan to be available may also be provided. 
Since many users will choose not to call mobile devices 
that are deactivated, wireless carriers may experience a 
reduction in unbilled resource utilization, since sub- 
scribers are generally not billed for calls to Inactive 

30 devices. The interaction between the mobile device of 
the user and the monitored mobile devices can be 
through a phone call or a text message, either of which 
can be rapidly achieved with minimal user effort by the 
inventive apparatus and method. 

35 [0007] Furthermore, the invention can be imple- 
mented in numerous ways, including as a method, an 
apparatus or device, a user interface, a computer read- 
able medium, and a system. Several embodiments of 
the invention are discussed below. 

40 [0008] As a mobile device, one embodiment of the 
invention includes a display screen, and computer pro- 
gram code for causing the display screen to display (i) 
an identifier for each of one or more portable, wireless 
two-way interactive communication device(s) and (ii) a 

45 Status indicator pertaining to each of the one or more 
mobile devices, and a processor operatively connected 
to the display screen, wherein the processor operates to 
execute the program code. 

[0009] As a method for operating a mobile device 
50 having a display screen, one embodiment of the inven- 
tion includes the stages of receiving status information 
for one or more monitored mobile devices, and produc- 
ing a screen display on the display screen in accord- 
ance with the status information received. The screen 
55 display produced may include identifiers for the moni- 
tored mobile devices and status indicators pertaining to 
the monitored mobile devices, with the status indicators 
Indicating whether the monitored mobile devices were 
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active or inactive during the last monitoring cycle. The 
screen display may include a short message from a 
user associated with a particular monitored mobile 
device (e.g. "I'm in a meeting"). 

[0010] As a user interface for a mobile device hav- s 
ing a display screen and an user interface, one embod- 
iment of the invention includes: a list of users from an 
address book assoc'eted with a first mobile device, one 
or more of the users being associated with other mobile 
devices; and a status Indication indicating an opera- io 
tionai status of a mobile device associated with one of 
the users on the list. The list of users and their status 
indications are displayed on the display screen of the 
first mobile device. Navigation through the list of users 
in an address book and selection of individual users is is 
achieved using the user interface of the first mobile 
device. 

[0011] As a computer readable medium including 
computer program code for operating a mobile device 
having a display screen, one embodiment of the inven- 20 
tion includes: computer program code for receiving sta- 
tus information (e.g. identifiers, short messages and 
activation status for designated mobile devices); and 
computer program code for producing a screen display 
on the display screen in accordance with the status 25 
information. The screen display may include an identi- 
fier, a short message and a status indicator for desig- 
nated mobile devices, the status indicator indicating 
whether the designated devices are active or inactive. 
Optionally, the computer readable medium may include 30 
code for interacting with a user to designate mobile 
devices for which status information is required. 
[0012] As a computer readable medium including 
computer program code for operating a mobile device 
having a display screen, another embodiment of the 35 
invention includes: computer program code for receiv- 
ing status information (e.g. an identifier, a short mes- 
sage and an activation status for designated mobile 
devices); computer program code for storing said 
received status information; computer program code for 40 
comparing user entered identifiers (e.g. a dialled phone 
number) with the received interface information; and 
computer program code for performing a desired action 
when an attempt Is made to interact with a designated 
mobile device having an insictive status Indicator or a 4S 
designated mobile device experiences a change in its 
status. 

[0013] The advantages of the present invention are 
numerous. Different embodiments or implementations 
may yield one or more of the following advantages. One so 
advantage of the invention is that users can be informed 
of status Infomnation pertaining to designated mobile 
devices. Another advantage of the invention is that 
users are able to send, receive and reply to short mes- 
sages to and from associates having mobile devices ss 
(e.g. instant messaging). Still another potential advan- 
tage of the invention is that status alerts can be pro- 
vided when designated mobile devices experience a 



change in status. Yet another advantage of the invention 
is a privacy control mechanism that allows the users of 
the monitored mobile devices to control the release of 
their own operational status information since there may 
be occasions where the user does not want this infor- 
mation released or desires to have control of the 
release of this information. 

[0014] Other aspects and advantages of the inven- 
tion will become apparent from the following detailed 
description taken in conjunction with the accompanying 
drawings, which Illustrate, by way of example, the princi- 
ples of the invention. 

BRIEF DESCRIPTION OF THE DRAWINGS 

[0015] The present invention will be readily under- 
stood by the following detailed description In conjunc- 
tion with the accompanying drawings, wherein like 
reference numerals designate like structural elements, 
and in which: 

Rgure 1 A is a block diagram of a wireless commu- 
nication system which may be utilized to implement 
the method of the present invention; 
Rgure 1 B is an illustration of a mobile device which 
may be used in conjunction with the wireless com- 
munication system described in Rgure 1A to imple- 
ment the method of the present invention; 
Rgure 2A is a diagram of a proxy server device 
which may be used in conjunction with the wireless 
communication system described in Figure 1A to 
implement the method of the present invention; 
Rgure 2B is a diagram of a representative data 
structure for a user account, which may be used to 
Implement the method of the present invention; 
Rgure 2C is a block diagram of a mobile device 
which may be used In conjunction with the wireless 
communication system described in Figure 1A to 
implement the method of the present invention; 
Rgure 20 is a block diagram of a database which 
may be used in implementing the method of the 
present invention; 

Rgure 3 A is a flow diagram showing the stages of 
the client-side associates list processing according 
to one embodiment of the invention; 
Rgure 36 is a flow diagram showing the stages of 
the server-side associates list request processing 
according to one embodiment of the invention; 
Rgure 3C is a flow diagram which provides addi- 
tional details relating to access rights associated 
with the status information described in Figure 3B. 
Rgures 4A and 48 are flow diagrams which provide 
additional details of the client-side associates list 
processing described in Figure 3A; 
Rgure 4C illustrates screen displays representative 
operations for an associates list having iconic sta- 
tus indicators according to one embodiment of the 
invention; 
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Rgure 40 illustrates screen illustrates an interactive 
associates list processing method according to an 
embodiment of the invention; 
Figure 5A is a flow diagram of the steps involved in 
notification processing according to one embodi- s 
ment of the Invention; 

Rgure 5B is a block diagram of a presence detec- 
tion system according to one embodiment of the 
invention; 

Rgure 6A is a flow diagram of application notlfica- io 
tion processing according to one embodiment of 
the invention; 

Rgure 6B illustrates a representative high priority 

notification message screen display; 

Rgure 6C illustrates a representative alert Inbox 75 

screen display having a brief alert message; 

Rgure 6D is a flow diagram of message read and 

reply processing according to one embodiment of 

the invention; 

Rgure 6 E illustrates a representative text message 20 
screen display that may be displayed on the display 
- screen of the mobile device; 

Rgure 7A Is a flow diagram of privacy settings 
processing according to one embodiment of the 
invention; 25 
Rgure 7B illustrates representative screen displays 
presenting an associates list and menu screens for 
setting of an alert; and 

Rgure 8 is a flow diagram of address book process- 
ing according to one embodiment of the invention. 30 

DETAILED DESCRIPTION OF THE INVEIsnriQN 

[0016] The present invention Is directed to a com- 
munication system that makes use of status information 35 
so that users of the communication system are informed 
about the status of designated portable wireless two- 
way interactive devices (also referred to as mobile 
devices herein) before attempting to establish contact 
with those devices. The method of communication 40 
between the mobile devices can be through a phone 
call or a text-based message, either of which can be 
rapidly achieved with minimal user effort (e.g. softkey 
activation). As such, a user of a mobile device is able to 
have an indication that the mobile device/associate (or 45 
devices/associates) of interest were active during a 
recent monitoring cycle prior to attempting to contact 
that device/associate (or devices/associates). 
[0017] Mobile devices include, but are not limited to 
personal digital assistants (PDA) portable devices^ eel- so 
lular phones, palm-sized computing devices, and wire- 
less capable remote controllers. It is not unusual for 
such devices to have less than 1% of the computing 
resources found in a personal computer. These mobile 
devices typically have a small display screen and a lim- 55 
ited user Interface mechanism (e.g., a phone keypad) 
for user interactions with server devices and wireless 
networks providing mobile subscriber services. These 



characteristics are useful in achieving the desired size, 
weight, power and mobility features which have proven 
to be important for mass-market mobile devices. 
[001 8] Embodiments of the invention are discussed 
below with reference to Figures 1A-8. However, those 
skilled in the art will readily appreciate that the detailed 
description given herein with respect to these figures is 
for explanatory purposes as the invention extends 
beyond these limited embodiments. 
[Q019] Figure 1A Is a block diagram of a wireless 
communication system 100 which may be utilized to 
Implement the method of the present invention. The 
wireless communication system 1 00 typically includes a 
plurality of mobile devices 102. The mobile devices 102 
are supported by a wireless carrier network 104 that 
facilitates voice and data communications to and from 
the mobile devices 102. The wireless carrier network 
1 04 couples to a wired network 1 08 through a gateway 
server 106. The wired networic 108 is, for example, the 
Internet, a local area network (LAN), or a wide area net- 
work (WAN). The wireless carrier network 104 can be 
any of a variety of types of wireless networks, for exam- 
ple, Cellular Digital Packet Data (CDPD). Global Sys- 
tem for Mobile Communications (GSM), Code Division 
Multiple Access (CDMA), Personal Handy Phone Sys- 
tem (PHS) and Time Division Multiple Access (TDMA) 
networks. 

[0020] Gateway server 1 06 can be referred to as a 
proxy server for the mobile devices 102 of wireless car- 
rier network 104. Since the communication protocol 
used in wireless cannier network 104 Is often different 
from that used In the wired network 1 08, one of the func- 
tions of the gateway server 106 is to translate from one 
communication protocol to another. One of ordinary skill 
in the art would understand that the functions of gate- 
way server 106 may be performed by a network server 
device which Includes or Is capable of including a con- 
nection mechanism between wireless carrier network 
1 04 and wired network 1 08. 

[0021] Wireless communication system 100 
includes a status information management server 110 
and an associate status server 112, whbh may be a 
separate server device or its functions may be per- 
formed by gateway server 1 06. According to the present 
Invention, mobile devices 102 can display and otherwise 
process lists of monitored associates, which m^ indi* 
cate not only an identifier for the users associated with 
particular mobile devices, but also status information for 
those mobile devices and short messages from the 
users (e.g. "I'll be available after 2 PM"). 
[0022] Status information management server 110 
retrieves and stores status Information for a plurality of 
mobile devices servfced by wireless network 104. Wire- 
less network 104 monitors device status Infonnation for 
serviced devices for use in conjunction with network 
operation and maintenance. Associate status server 
1 12 maintains a Dst or record of mobile devices/associ- 
ates to be monitored for the subscribers (also referred 
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to as users) of mobile devices 102. Status information 
for the monitored mobile devices/associates is man- 
aged and updated as required. In accordance with the 
principles of the present invention, this information ma/ 
include monitored device activation status, changes in 5 
activation status and short messages from the users of 
the monitored devices. 

[0023] A wireless carrier infrastructure is associ- 
ated with wireless carrier network 1 04. For example, the 
wireless carrier infrastructure generally includes a base 
station and an operations and maintenance center. The 
base station controls radio or telecommunication links 
with the mobile devices serviced. The operations and 
maintenance center typically Includes a mobile switch- 
ing center that performs the switching of calls between 
the mobile devices and other fixed or mobile network 
users. Further, the operations and maintenance center 
manages mobile services, such as authentication and 
oversees the proper operation and setup of the wireless 
network. The wireless carrier infrastructure also main- 
tains user accounts for each of the mobile network 
users. Status information for the mobile device may be 
associated with a user account. This status information 
may include user identification Information, device acti- 
vation status, and a short message from the user or 
location information. 

[0024] According to one embodiment, the commu- 
nication protocol used by status information manage- 
ment server 110 and the wired network 1 08 is the well 
known HyperText Transfer Protocol (HTTP) or Secure 
HyperText Transfer Protocol (HTTPS), a secure version 
of HTTP, and runs on Transmission Control Protocol 
(TCP). In one embodiment, the communication protocol 
between the wireless communication devices 102 and 
the gateway server 106 via the wireless carrier network 
1 04 Is Handheld Device Transport Protocol (HDTP) (for- 
merly known as Secure Uplink Gateway Protocol 
(SUGP)) or Wireless Access Protocol (WAP). 
[0025] The associate's list and short messages 
may be generated in a markup language such as Hand- 
held Device Markup Language (HDML) and Wireless 
Markup Language (WML). HDML and WML are similar 
to HyperText Markup Language (HTML) in that they are 
tag based document languages. HDML and WML use a 
set of commands or statements specified in a group of 
cards (referred to as a deck) that specify how informa- 
tion is to be displayed on a display screen of the mobile 
devices 102 and how the mobile devices 102 operate 
with respect to user interaction with the display screen. 
Normally, a number of cards are grouped Into the deck 
and the deck is exchanged between the mobile devices 
102 and gateway server 106. Further, as would be 
understood by one having ordinary skill in the art, the 
invention may be practised by directly coupling the wire- 
less carrier network 104 to the wired network 108 with- 
out using the gateway server 106. Alternatively, a server 
device contained within the framework of the wired net- 
work 108 could perform the functions of the gateway 



server 106. 

[0026] Note that the mobile devices 1 02 can also be 
referred to as wireless client devices or wireless com- 
munication devices. The mobile devices 102 can take a 
variety of forms, including personal digital assistants 
(PDAs), mobile telephones (e.g., cellular telephones), 
etc. Typically, as noted above, the mobile devices 102 
include a screen display and have processing capabili- 
ties, whk:h Is less robust than that associated with con- 
ventional personal computers. - 

[0027] Figure 1 B is an Illustration of a mobile device 
150, which may be used in conjunction with the wireless 
communication system described in Figure 1 A to imple- 
ment the method of the present Invention. Mobile device 
150 may be, for example, a mobile telephone suitable 
for use as mobile devices 102 illustrated in Figure 1A. 
The wireless communication device 150 includes a dis- 
play screen 152, a keypad 154, softiceys (156A and 
156B) and associated softkey identifiers 158A and 
1588 that allows a user thereof to interact with mobile 
device 150. Additionally, the mobile device 150 includes 
a speaker 158 and a microphone 160 as may be found 
in conventional mobile telephones. 
[0028] Keypad 154 includes, in one embodiment, a 
typical phone keypad and various control buttons, such 
as generic buttons and navigation (e.g., upward and' 
downward arrow) buttons. The typical phone keypad 
includes twelve buttons, of which ten buttons are con- 
secutively numbered 0 to 9, one button is for **" sign, 
and another button is for °#" sign. Although not neces- 
sary for practising the invention, the keypad 154 pro- 
vides convenient means for a user to interact with 
mobile device 1 50. It should be understood, by one hav- 
ing ordinary skill in the art, that having a phone keypad 
is not a requirement to practice the present invention. 
Some mobile devices have no physical keys at all, such 
as those palm-sized computing devices that use soft 
keys or icons as an input mechanism. 
[0029] In accordance with the principles of the 
present invention, a user of a mobile device (e.g. mobile 
device 102) has access to status information relating to 
one or more monitored mobile devices. The particular 
mobile devices selected for monitoring may be associ- 
ated with a user/network application (e.g. an address 
book), input by the user directly, or generated by a third 
party as a result of some affiliation between the 
user/mobile devk:e receiving the status information and 
the users/mobile devices being monitored. Regardless 
of the means of identification, a list or grouping of 
mobile devices to be monitored for a particular user is 
stored on a server devbe (e.g. associates status server 
112). The associates status server 112 periodcally 
requests status information for monitored mobile 
device. These requests are fonwarded to the status 
information management server 1 1 0 whk:h retrieves the 
requested status information for the monitored mobile 
devices from associated network resources (i.e. a 
Home Location Register (HLR) or a Visitor Location 
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Register (VLB) associated with a monitored mobile 
device). This information is stored and passed to the 
requesting entity (e.g. users of mobile devices 102) 
exercising control over the iist/grouping of monitored 
mobile devices described above. One ot ordinary skiW in 5 
the art would understand that the functions of the status 
information management server 1 1 0 and the associates 
status server 112 may be performed by a single server 
device. Additionally, the functions of both the status 
information management server 110 and the associates 70 
status server 112 may be performed by gateway server 
106. 

[0030] Rgure 2A is a block diagram of a gateway 
server device 200, which may be used in conjunction 
with the wireless communication system described in is 
Rgure 1A to implement the method of the present 
invention. Gateway server device 200 is, for example, 
gateway server 106 of Rgure 1A. Gateway server 
device 200 is coupled between the wired networl< 108 
and the wireless carrier network 104 of Figure 1A and 20 
perfomns tasks associated with network access, proto- 
col conversion and account management. To avoid 
obscuring the primary aspects of the present invention, 
well-known methods, procedures, components and cir- 
cuitry associated with gateway server device 200 are 25 
not described in detail. 

[0031] Gateway server device 200 includes a Land 
Control Protocol (LCP) interface 202 that couples to 
wired network 108, and a Wireless Control Protocol 
(WCP) interface 206 that couples to the wireless carrier 30 
network 104. A server module 210 is coupled between 
the LCP interface 202 and the WCP interface 206. 
[0032] Server module 210 performs traditional 
server processing as well as protocol conversion 
processing from one communication protocol to another 35 
communication protocol (I.e. between the protocol used 
by wireless networks and protocols used by the wired 
networks). According to one embodiment, the protocol 
conversion processing can be implemented as a sepa- 
rate module referred to as a mapper. In the case of pro- 40 
tocol conversion between HDTP and HTTP, the 
conversion is a data mapping relationship. As would be 
understood by those skilled in the art, WCP interface 
206 can be readily replaced by another interface mod- 
ule when the wireless carrier network 1 04 uses a differ- 4S 
ent communication protocol; the same is true of LCP 
interface 202 when the wired network 108 uses a differ- 
ent communication protocol. 

[0033] The server module 210 also includes an 
account manager 212 and an account interface 214. so 
Account manager 212 manages a plurality of user 
accounts for the mobile devices serviced by the proxy 
server device 200. It is understood that the user 
accounts may be stored in another network server cou- 
pled to the proxy server device 200. In other words, the ss 
user accounts can be kept in a database that is physi- 
cally placed in another computing device coupled to the 
wired network 108. 



[0034] Gateway server device 200 also includes a 
processor 218 and a storage component 220. Proces- 
sor 218 performs operations in accordance with instruc- 
tions from server module 210. It would be understood 
by those skilled in the art that gateway server device 
200 is a piece of hardware equipment that includes one 
or more processors (e.g., processor 218), working 
memory (e.g., storage 220), buses, interfaces and other 
components. Server module 210 includes program 
code, which causes proxy server device 200 to perform 
designated tasks. It would also be understood by those 
skilled in the art that proxy server device 200, may per- 
form the functions of the associates status server (e.g. 
112 of Rgure 1 A). 

[0035] Rgure 2B is a diagram of a representative 
data structure 222 for a user account, which may be 
used to implement the method of the present invention. 
As previously noted gateway server device 200, which 
may be gateway server 106 of Figure 1A, maintains 
user accounts for various users or subscribers. These 
user accounts are also known as subscriber accounts. 
The representative data structure 222 includes a device 
ID field 224, a subscriber ID field 226, and a user infor- 
mation field 228. Device ID field 224 includes a device 
ID, and subscriber ID field 226 includes a subscriber ID. 
For example, in Rgure 2B, the representative device ID 
is "93845823", and the representative subscriber ID is 
"861234567-10900j3n.mobile.xyz.net*'. The user Infor- 
mation 228 can include account configuration infomna- 
tion, user preferences, etc. These lists or groups of 
mobile devices/associates to be monitored may be 
stored in association with the user account file for the 
entity receiving the status information for the monitored 
mobile devices. 

[0036] Figure 2C is a block diagram of a mobile 
device 250, which may be used in conjunction with the 
wireless communication system described in Rgure 1 A 
to Implement the method of the present Invention. 
Mobile device 250 includes a WCP interface 252 that 
couples to wireless network 1 04 via a radio-frequency 
(RF) transceiver (not shown) to receive incoming and 
outgoing signals. A device identifier (ID) storage 254 
supplies a device ID via WCP interface 252. 
[0037] The device ID identifies a specific code that 
is associated with mobile devtoe 250. The device ID is 
used by gateway server devtee 200 to associate the 
mobile device 250 with a user account stored in the 
gateway server de\^ce 200. The device ID can be a 
phone number of the device or a combination of an IP 
address and a port number. An example of a combina- 
tion of an IP address and a port number is 
204.163.165.132:01905 where 204.163.165.132 Is the 
IP address and 01 905 is the port number. The device ID 
is further associated with a subscriber ID (i.e. in the 
Equipment Identification Registry (EIR) and the Home 
Location Registry (HLR)) authorized by a wireless car- 
rier network as part of the procedures to activate a sub- 
scriber account for the mobile device 250. The 
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subscriber ID may take the form of, for example, 
861234667-10900_pn.mobile.att.net by AT&T Wireless 
Service. The subscriber ID is a unique Identification for 
mobile device 250. Each of the mobile devices serviced 
by a proxy server device (e.g. gateway server device 
1 06 of Figure 1 ) has a unique device ID that is associ- 
ated with a respective user account. 
[0038] Mobile device 250 also includes voice cir- 
cuitry 266 (e.g., a speaker and a microphone) and the 
associated hardware (e.g., an encoder/decoder 264, a 
processor 268 and Iceypad circuitry 262) which provide 
telephony functions in a telephone mode of operation 
which is separate and distinct from a data mode of oper- 
ation used when interfacing with a proxy server device. 
In the telephone mode of operation, a user can cause 
mobile device 250 to place a phone call to another party 
having a phone, either wireless or land-based. 
[0039] Mobile device 250 includes a client module 
256, which works in conjunction with processor 268 and 
the working memory 258 to perform the processing 
tasks perfomied by mobile device 250. These include: 
establishing a communication session with a proxy 
server device via a wireless network, requesting and 
receiving data via the wireless network, displaying infor- 
mation on the mobile device display screen through the 
use of display circuitry 260, and receiving user Input 
from a user via a keypad controlled by keypad circuit 
262. Additionally, client module 256 contains computer 
code to cause processor 268 to execute instructions to 
control the operation of, among other things, a browser. 
In one embodiment, the browser is a micro-browser, 
which typically requires less computing power and 
memory than the HTML browsers used in personal 
computers. One such micro-browser is available from 
Phone.com located at 800 Chesapeake Drive, Red- 
wood City. CA 94063, the assignee of the present inven- 
tion. 

[0040] Figure 2D is a block diagram of database 
storage 280, which may be used in conjunction with the 
implementation of the method of the present invention. 
Database storage 280 includes a status data store 282, 
an associates mapping data store 284, and a nriessage 
data store 286. Status data store 262 stores status 
information for monitored mobile devices on the user's 
associate list. Associates mapping data store 284 
stores the user's lists of associates and any infonnation 
required to retrieve status information for those associ- 
ates (e.g. user identifiers and access rights). Message 
data store 286 stores messages being exchanged 
between subscribers or users of the wireless communi- 
cation system 100. More specifically, message data 
store 286 stored in the database 280 may be used to 
store "Instant text messages' that can be exchanged 
between mobile devices. Some of these messages may 
be stored by the user of a monitored mobile device and 
scheduled tor delivery when an inquiry is made as to the 
status of that device. For example, if the user of a mon- 
itored mobile device Intends to have their device off for 



12 

the weekend they can create and store a message to 
that effect, 

[0041] The status data store 282 stores, updates 
and manages status information for monitored mobile 

5 devices on a user's list This status information includes 
the activation status of the monitored mobile device. 
The activation status may be active (on-line) , inactive 
(off-line) or inactive with the time period of inactivity 
given. The activation status represents the last known 

10 activation status of the monitored device as registered 
during a preceding monitoring cycle. Active or on-line 
typically means that the mobile deybe Is registered with 
a wireless network and can send and receive messages 
(e.g. phone calls or data messages). A representative 

15 SQL table of a relational database that can implement 
the status data store 282 is as follows: 

Create table associate_status_tbl ( 
20 associatejd varchar2(128) not null, 

status varchar2(32), 
name varchar2(256), 
phone varchar2(128), 

25 



primary keyCsub^no) 



[0042] In this example, the associate identifier col- 
umn represents an internal identifier used by the status 

55 data store 282 to identify a subscriber. The status col- 
umn is used to hold the status of the subscriber's mobile 
device. The name column contains the subscriber's 
name. The phone column contains the phone number of 
the subscriber's mobile device. Hence, this SQL table 

40 not only provides status information for associates but 
also related infomnation such as phone number and 
name, which may be used by user interfaces to facilitate 
communications. 

[0043] The associate mapping data store 284 
45 stores data identifying the associates of the user. The 
associate mapping data store 284 may also store infor- 
mation relating to the wireless carrier network providing 
service to the associate's mobile device and alert types 
to be provided. A representative SQL table of a rela- 
50 tional database that can implement the associate map- 
ping data store 284 Is as follows: 
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create table associate_mapplng_tbl ( 
rid integer not null, 

subscriber varchar2(1 28), 
associate varchar2(128), 
status varchar2(32), 
presencQ^alert varchar2<32), 
message^alert varchar2( 32) 

); 



[0044] The subscriber column is the unique identi- 
fier representing the user (subscriber). The associate 
column is the unique identifier representing an associ- 
ate of the subscriber (I.e., an associate Is on the sub- 
scriber's associate list). The unique identifier 
representing an associate of the subscriber may include 
information relating to the carrier network providing 
service to the associate. The status column is used to 
hold the status of the subscriber's mobile device as reg- 
istered during the most recent monitoring cycle. The 
message alert column determines whether the sub- 
scriber desires a message alert when the activation sta- 
tus of a monitored mobile device changes. 
[0045] Note that alerts relating to activation status 
changes in monitored mobile devices may be sent to 
parties other than the suk>scriber who initiated status 
monitoring. For example, consider the situation where a 
subscriber desired to set up a teleconference with a plu- 
rality of associates having mobile devices and one of 
the associates was off-line. When the activation status 
of the off-line associate changes an alert could be sent 
to all parties concerned, notifying them that the telecon- 
ference could (or would) now proceed. 
[0046] The message data store 286 is responsible 
for storing the text messages that users send to each 
other. A representative SQL table of a relational data- 
base that can implement the message data store 286 is 
as follows: 



create table buddy_msg_tbl 
{ 
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15 



20 



25 



30 



35 



40 



45 



50 



55 



subscriber 

associate 

rid 

message 

name 

phone 

need_alert 

read 

sent_date 
primary key 



varchar2(128), 
varchar2(128), 

integer, 

varchar2(1024), 
varchar2(256), 
varchar2(1 28), 
chard), 

chard), 
date not null, 

(sub no, rid) 



); 



[0047] The message column contains the mes- 
sage, and the sent.date column contains the date the 
message was sent. The need_alert column provides an 
Indication that the subscriber desires an alert when the 
activation status of a monitored associate's mobile 
device changes. 

[0048] Rgure 3A is a flow diagram showing the 
stages of the client-side associates list processing oper- 
ation 300 according to one embodiment of the present 
invention. The associates list processing operation 300 
is, for example, performed on a mobile device, such as 
the mobile devices 102 Illustrated in Figure 1 A. 
[0049] Associates list processing operation 300 is 
initiated by user Interaction via the user Interface of the 
mobile device. Once initiated, a request for associates 
information is sent at 302 to the associates status 
server (e.g. associates status server 1 12 of Figure 1 A). 
Then a determination is made 304 as to whether a reply 
to the request has been received from the associates 
status server. When a determination is made 304 that 
the reply has not yet been received, the associates list 
processing operation 300 awaits the reception of the 
reply until the reply is received or a time-out is reached. 
Once the reply to the request (e.g. an associates list 
including status information) has been received, the 
associates list, with status information including mobile 
device activation status, is processed (e.g. displayed) 
by the requesting device 306. 

[0050] Next, a determination Is made 308 as to 
whether user input has been received. Once user input 
has been received, a determination is made 309 as to 
whether the user has requested to discontinue the 
associates list processing operation 300. For example, 
a user may detemnlne that the mobile device for an 
associate of interest is off-line and may want to end 
processing. When the determination is made 309 that 
the associates list processing operation 300 is to end, 
the associates list processing operation 300 is terml- 
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nated. Otherwise, if the mobile device for the associate 
of interest is on-line, a decision 310 determines whether 
a text message or a voice call (or some other communi- 
cations method such as causing the contacted device to 
vibrate or make some sound or perform some other 
task) is to be made or sent to the selected one of the 
associates of the displayed associates list Here, both 
the sending and receiving communication devices are 
assumed to support both text messages (e.g., instant 
messages), voice calls and/or other communication 
means (e.g. audio and non-audio alerts). Often, a user 
desiring to communicate with an associate will prefer 
sending a short text message to the associate -such as 
when either user is in a meeting and cannot carry on a 
voice call but can discretely send a short text message. 
[0051] When a determination is made 310 that a 
voice call Is to be attempted, a call to the selected asso- 
ciate may be initiated 312. On the other hand, when the 
detennination is made 31 0 that a text message is to be 
sent, the mobile device enters a text entry mode of 
operation where a user of the mobile device may enter 
a text message. Next, the entered text message is sent 
316 to the selected associate. After the text message is 
sent the associates list processing operation 300 is 
complete and ends. 

[0052] According to the principles of the present 
invention, a list or grouping of mobile devices to be mon- 
itored for a requesting rhobile device is maintained and 
managed on a remote server device (e.g. associates 
status server 112 of Figure 1A). When a user of the 
monitoring mobile device requests, this list or grouping 
isfonvarded via a wireless communication network (e.g. 
wireless carrier network 104 of Figure 1 A) in a format 
that may be processed by the requesting mobile device. 
That format may take any suitable form, for example, a 
markup language such as HDML, WML, XML, HTML, or 
cHTML. Once received by the requesting mobile device, 
the list or grouping may be displayed and the user of the 
requesting mobile device may take some action based 
on the information contained in the list or grouping. That 
action may be an attempt to contact one or more of the 
users of one of the monitored mobile devices based on 
contact information (e.g. phone numbers or URIs) 
embedded in or otherwise associated with the list or 
grouping. 

[0053] Figure 36 is a flow diagram of associate sta- 
tus information request processing operation 350 by a 
server device having access to that information accord- 
ing to one embodiment of the present invention. The 
associates status information request processing oper- 
ation 350 is, for example, performed by the Status Infor- 
mation Management Server System 110 as illustrated 
in Figure 1A. 

[0054] Associates status information processing 
operation 350 begins with a determination 352 as to 
whether a request for status information for one or more 
associates on an associates list (i.e., the monitored 
mobile devices associated with users of interest) has 



been received at a first server device having access to 
that information. The request may be sent by a second 
server device (e.g. associate status server 112 of Rg- 
ure 1 A) acting on behalf of a mobile device (e.g. mobile 

5 devices 1 02 of Figure 1 A) or by the mobile device itself. 
It is important to note that the functions of the status 
information management server (e.g. 110 of Figure 1 A) 
and the associate status server may be performed by 
the same server device if the monitoring and monitored 

70 mobile devices belong to the same wireless can'ier net- 
work. 

[0055] The associate of interest may be identified 
by a subscriber identifier retrieved from a database 
(e.g., associates mapping data store 284). Next, a 

15 determination is made at 354 as to whether the reques- 
tor has access rights to the requested status informa- 
tion. The user of a monitored mobile device would 
typically need to provide some indication that the 
requested information may be released. For example, 

20 when the account for the monitored mobile device is set 
up, the user could specify that this information may be 
universally released when requested or a request for a 
release could be sent to the user. Access rights are 
described In further detail below. 

25 [0056] If the user has access rights to the 
requested status information, then the information is 
retrieved at 356. Othenwise the process is tennlnated. 
The retrieved status information and related information 
is forwarded to the requesting entity 358 (i.e. associate 

30 status server 112) and ultimately to the monitoring 
mobile device in a suitable fomiat. For example, with a . 
mobile device using a network browser supporting 
HDML, then one suitable display format would be an 
HDML deck in which a series of screen displays are pro- 

35 vided within the deck. The suitable display format could 
also be a text file or a markup language such as WML, 
HTML, XML, compact HTML or any suitable file fomnat. 
Information relating to the status of monitored mobile 
devices may also be presented to the user using sym- 

40 bols (e.g. icons), sounds and other notification methods. 
[0057] Figure 3C Is a flow diagram which provides 
additional details relating to access rights which may be 
associated with the status information described above. 
When a request for status information for a designated 

45 mobile device (i.e. Mobile Device A) Is received at 362, 
where that request is associated with a subscriber's 
associates list (i.e. Subscriber 8's List), then a detenmi- 
nation is made at 364 as to whether the subject sub- 
scriber (I.e. Subscriber B) has received permission from 

50 the user of the subject mobile device (i.e. Mobile Device 
A) to receive the requested status infomnation. If the 
subject subscriber has pennlssion to receive the 
requested status information (access rights), then the 
requested status information for the subject mobile 

55 device (i.e. Mobile Device A) is retrieved at 366 and the 
subject subscriber's list (i.e. Subscriber B's List) is 
updated. 

[0058] According to the principles of the present 



17 



EP 1 071 295 A2 



18 



invention, a list of mobile devices allowing access to 
their status Infonnatjon may be generated and associ- 
ated with a monitoring mobile device. The status infor- 
mation for the monitored mobile devices, which may 
include device activation status, device status change 5 
or a short message from the user of one of the moni- 
tored mobile devices, is retrieved from the wireless net- 
work entity which traci<s such information. This 
information may be stored on an intermediate server 
device (e.g. associates status server 1 12 of Rgure 1 A) 10 
where It is managed and updated as required. When the 
monitoring mobile device requests this information, a 
file in a suitable format (e.g. a markup language) is for> 
warded. Once received, the monitoring mobile device 
processes this file. When the user of the monitoring 75 
mobile device examines the associates list or attempts 
to contact one of the monitored associates, status Infor- 
mation relating to the monitored mobile devices is pre- 
sented on the display screen (or via some other aspect 
of the user interface) of the monitoring mobile device. 20 
This allows the user to make an informed decision as to 
whether or when (or how) to contact the user of one of 
the monitored mobile devices. 

[0059] Figures 4A and 4B are flow diagrams which 
provide additional details of the client-side associates 25 
list processing operation 400 described In conjunction 
with Figure 3A above. The associates list processing 
operation 400 is, for example, performed by a client 
application that is executed by a mobile device, such as 
the mobile devices 102 illustrated in Figure 1A. 30 
[0060] Associates list processing operation 400 is 
initiated when a user of a mobile device requests the 
display of a current associates list. Once initiated, a 
request for an associate list is sent 402 to the server 
device having access to the status information (e.g., 3s 
associate status manager 112 of Figure 1A). Then, a 
determination Is made 404 as to whether a reply has 
been received to the request. If a reply has not yet been 
received, the associates list processing operation 400 
awaits the reception of the reply from the server device 4o 
processing the request or a expiration of a predefined 
time period. Once a determination is made 404 that the 
reply has been received, an associates list and associ- 
ated status information are displayed 406. The associ- 
ates fist can be provided as text or may be provided In a 45 
format such as a deck of iHDiV^L cards. Such HDML 
cards could include a priority designator, a message 
body, or a Universal Resource Locator (URL) that points 
to another deck of cards which may provide Information 
needed for subsequent actions. 50 
[0061] At this point, as explained in detail below, the 
associates list processing operation 400 waits for a user 
of the mobile device to Interact with the mobile device to 
make a selection, typically a selection with respect to 
designation of one of the associates on the associates 55 
list being displayed. As discussed below, in this embod- 
iment, associates list processing operation 400 controls 
designation of an associate, creating and sending text 



messages, initiating voice calls, or other processing 
tasks. 

[0062] Once the associates list and any associated 
status information are displayed 406, a determination is 
made 408 as to whether a user input has been received. 
If the determination is made 408 that a user input has 
not yet been received, associates list processing opera- 
tion 400 awaits the reception of a user input or a time- 
out. Once the determination has been made 408 that a 
user Input has been received, a determination is made 
410 as to whether the user input Is an associate selec- 
tion. When the determination is made 410 that the user 
has selected a particular associate, a status indicator 
for the selected associate is displayed 412 fif not 
already displayed) and any associated messages are 
also displayed (I.e. "In a Meeting Till 5"). Status indica- 
tors may be displayed/updated for all monitored associ- 
ates when the associates list is displayed/updated or 
status information may be provided only when a partic- 
ular associate is selected. 

[0063] When a detemilnation is made 410 that a 
user input is not an associate selection, then another 
detemiinatlon is made 414 as to whether the user input 
is a voice call request. When the detemriination Is made 
414 that the user Input Is a voice call request, a call con- 
firmation is displayed 416. The display 416 of the call 
confimnation is optional but can be useful to inform the 
user of the phone number or address to be called. The 
call Is placed at 420 to the selected number. Following 
the placement of the call, the associates list processing 
operation 400 is complete and ends. 
[0064] When the detenmlnatlon is made 414 that 
the user input is not a voice call request, another deter- 
mination is made 422 as to whether the user input is a 
text message request. When the determination Is made 
422 that the user input is a text message request, a text 
entry area is displayed 424. The text entry area allows 
the user to enter the text for the text message to be sent. 
Another determination is then made 426 as to whether 
a user has finished providing the text for the text mes- 
sage and has requested to send the text message. 
Once the determination Is made 426 that the text mes- 
sage has been entered in the text display area and a 
request to send the text message has been received, 
then the text message is sent 428 to the selected asso- 
ciate. After the text message has been sent 428, the 
associates list processing operation 400 is complete 
and ends. 

[0065] Note that since the call or text message was 
requested through the associates list, the user of the 
mobile device performing the associates list processing 
operation 400 is able to determine whether the mobile 
device of the associate of interest Is able or unable to 
receive a message (a text message or a voice call) 
before attempting to deliver the message. Note also that 
the user of the mobile device performing the associates 
list processing operation 400 need not enter the phone 
number or address of the associate designated for 
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receipt of a message because that information may be 
extracted from the associates list by means well known 
in the art. 

[0066] When the determination is made 422 that 
the user Input is not a text message request, another 5 
determination is made 430 as to whether the user input 
is for another type of request. When the determination is 
made 430 that the user input is another type of request, 
other processing may be performed 432 as required. 
Such other processing can vary widely with Implemen- io 
tation, but may include forwarding a message (voice or 
text) to an alternate device associated with the moni- 
tored mobile device or causing the mobile device of 
interest to perform some task (e.g. an audio or non- 
audio alert). Following this other processing, the assocl- is 
ates list processing operation 400 is complete and 
ends. 

[0067] Alternatively, when the determination is 
made 430 that the user input is not another type of 
request, another determination Is made 434 as to 20 
whether the user desires to end the associates list 
processing operation 400. As an example, once the 
associates list processing operation 400 Is terminated 
(or otherwise ends), the client application on the wire- 
less communication device can transition to another 25 
mode or application. When the determination is made 
434 that a temiination request has been received, the 
associates list processing operation 400 is complete 
and ends. On the other hand, when the decision 434 
determines that a termination request has not been 30 
received, then the associates list processing operation 
400 returns to 408 as is shown in Figures 4A and 4B. 
[0068] As an example of a representative graphical 
user interface for the associates list processing opera- 
tion 400, Figure 4C illustrates screen displays associ- 35 
ated with presenting an associates list and sending a 
text message. Initially, a screen display 450 having an 
associates list 451 is displayed. Here, presumably, the 
user of the mobile device having screen display 450 dis- 
played on its display screen lists "Bill Jobs", "Steve 40 
Gates" and "John Doe" as associates within the associ- 
ates list 451 . Screen display 450 also Includes a selec- 
tion indicator 452 indicating the particular one of the 
entries being selected. In this example, the first entry 
("Bill Jobs") is selected. Screen display 450 also dis- 4S 
plays status indicators 454, 456 and 457. The status 
indicators 454, 456 and 457 are displayed based on the 
status information for the selected associate's mobile 
device. The status indicators 454 and 456 displayed 
adjacent to "Bill Jobs" and "Steve Gates" respectively so 
indicate that these associates have their mobile device 
active (or on-line) as of the last monitoring cycle. The 
status indicator 457 displayed adjacent "John Doe" indi- 
cates that the associate's mobile device is inactive (or 
off-line) as of the last monitoring cycle. The screen dis- 55 
play 450 also provides a "Contact" softkey 458 which 
enables the user to send either a text or voice message 
to the selected associate, and a "Menu" softkey 460 



which enables the user to refresh the display screen 
with a Menu screen display offering the user additional 
choices. 

[0069] Upon user selection of the "Contact" softkey 
458 with the selected associate being "Bill Jobs", a 
screen display 462 is presented on the display screen. 
The screen display 462 indicates the associate and pro- 
vides the user with a choice of message type, namely, 
place a voice call or send a text message. The screen 
display 462 also includes a selection indicator 464 that 
the user can control to pick the message type to be 
used. The screen display 462a shows the voice call 
message type being selected, and thus has a "Call" 
softkey 466. When the user activates the "Call" softkey 
466, the voice call is invoked. Alternatively, when the 
select indicator 464 indicates that a text message is 
desired, screen display 462b is presented on the display 
screen. In this case, the softkey 466 is a "Send" softkey 
468. Upon activation of the "Send" softkey 468, a 
screen display 470 is presented on the display screen 
and allows the user to enter text for a text message. 
[0070] In one embodiment, the status information 
management server system returns a deck of cards 
(e.g., HDML or WML cards) to the mobile device that 
implement the associates list with associated status 
information. The deck of cards, for example, can be 
used to implement the display screens 450, 462a, 462b 
and 470 shown in Figure 4C. 

[0071] Figure 4D illustrates screen Illustrates an 
interactive associates list processing method according 
to an embodiment of the invention. In this alternate 
embodiment a user attempting to contact "John Doe" by 
dialling his phone number 480 when his mobile device 
is listed as inactive might see a screen display like that 
presented in screen display 484. In this example, the 
associates mobile device activation status Information is 
stored in the background and an attempt to dial a 
number for a particular mobile device having an off-line 
status indication causes a text message to be gener- 
ated which indicates that ''John Doe's" phone is inactive 
but gives the user the option of trying the call anyway or 
requesting notification when "John Doe's "phone 
becomes active 490. 

[0072] Figure 5A Is a flow diagram of the steps 
involved in notification processing operation 500 
according to one embodiment of the invention. Notifica- 
tion processing operation 500 is, for example, per- 
formed by a network browser or client-application 
executing on a mobile device. Notification processing 
operation 500 begins with a detemiination 502 as to 
whether an alert is requested, in effect when an alert is 
requested, notification processing operation 500 is ini- 
tialized. In particular, when a determination is made 502 
that an alert Is requested, a list of alert types is dis- 
played 504, for example, on the display screen of the 
mobile device. Then, one of the alert types is selected 
506 by a user of the mobile device. Next, an alert of the 
selected type is setup 508 for a selected associate. Typ- 
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ically, the alert is setup by notifying the status Informa- 
tion management system (110 of Rgure 1A) that an 
alert should be sent to the mobile device of the user (of 
the monitoring mobile device) when a designated 
mobile device displays a status change. Foitowing alert 5 
setup 508, the establlsh-notificatlon processing opera- 
tion 500 Is complete and ends. 

[0073] Rgure 5B is a block diagram of a presence 
detection system 550 according to one embodiment of 
the Invention. The presence detection system 650 10 
includes a status Information management server 552, 
which couples to a gateway server device 554, a Short 
Message Service Center (SMSC) 556, and a mobile 
switching center 558. Presence detection server 552 is 
a network server that collects and consolidates availa- is 
bility information for monitored mobile devices from var- 
ious sources. Status information management server 
552 can integrate with a variety of network elements in 
order to gather a near real time portrait of the status 
information for a plurality of monitored mobile devices. 20 
The precise integration technique will depend on the 
particular wireless network the mobile device Is utilizing. 
For example, in a North American CDMA (IS-95) wire- 
less network, the status Information management 
server 552 can integrate with an IS-41 network to gather 2s 
IS-41 events, such as mobile activation. In a GSM net- 
work, the status information management server 552 
could gather MAP events. Similarly, In other types of 
networks, the status Information management server, or 
a functional equivalent, will gather status tnfomiatlon 30 
relating to designated monitored mobile devices. 
[0074] The status Information management server 
552 will also be capable of gathering events and infor- 
mation from other network elements, including the gate- 
way setver device 554 and the SMSC 556. In one 35 
embodiment, the status information management 
server 552 receives a variety of platform-specific 
events, and applies techniques specific to those events 
in order to determine subscriber availability. For exam- 
ple, gateway server device 554 knows when the sub- 40 
scriber's mobile device has registered for a browsing 
session, and can report this as an event As another 
example, the SMSC 556 knows when messages are 
pending for the user (i.e., indicating user unavailability). 
As still another example, the mobile switching center 4S 
558 will know when the mobile device registers with the 
network, when it misses a periodic re-registration, etc. 
These events can be analysed to obtain a reliable indi- 
cation of the overall status of a monitored mobile device. 
For example, if the SMSC 556 reports that messages so 
are pending, then the mobile devbe is marked as not 
available. Later, the MSC 556 may report that the 
mobile device has registered on the network, indicating 
that the mobile device is once again available. 
[0075] In one embodiment, status information ss 
stored In the status data store 282 and the associate 
mapping data store 284 is used to trigger status notifi- 
cations. The status Information mana^ment server 552 



Is responsible for updating the status field in the status 
data store 282. A representative algorithm for these pur- 
poses is as follows: 

Find all users in the status data store 282 
(associate_status_tbl) who are on someone's asso- 
ciate list and whose status in the status data store 
282 is different than the status in the associate 
mapping data store 284 (friend^mapping^tbl). If the 
data store where an SQL database, this would be 
accomplished by the following: 

SELECT 

B.rid, B.subscriber, A.status, A.name, 
A.phone, B.presence.aiert 

FROM 

associate_status_tbl A, associate_map- 
ping_tbl B 

WHERE 

A.subscriber = B.associate AND NOT 
A.status = B.status 

For each such user, then (I) update the status in the 
associate mapping data store 284 with the value in 
the more current status in the status data store 282, 
and (11) send a notification to the subscriber indicat- 
ing that the associate's status has changed, pro- 
vided the subscriber desires to receive such 
notifications (and is authorized to receive such 
information). 

[0076] Rgure 6A is a flow diagram of application 
notification processing operation 600 according to one 
embodiment of the invention. Application notification 
processing operation 600 is initialized when a mobile 
device receives an alert notification. The alert notifica- 
tion pertains to an alert previously setup in accordance, 
for example, with the establish notification processing 
operation 500 illustrated in Figure 5A. 
[0077] The application notification processing oper- 
ation 600 begins with a determination 602 as to whether 
a status alert has been received. Once a status alert 
has been received, the application notify processing 
operation 600 is effectively initialized. Once initialized, 
the received status alert Is placed 604 In an alert Inbox. 
The alert typically resides in the memory of the mobile 
device that received the status alert. In other words, the 
incoming status alert is associated with the particular 
mobile device that previously setup the alert request. 
Next, a determination Is made 606 as to whether the 
received status alert Is a high priority alert When the 
detennination is made 606 that the received status alert 
is a high priority alert, a notification message informing 
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of the status change that invoked the status alert is dis- 
played 608. When the received status alert is not a high 
priority alert, a decision is made 606 which causes the 
displaying 608 of the notification message to be 
bypassed or delayed. 5 
[0078] In general, the priority levels for the alerts 
can include high priority, medium priority, low priority 
and no priority. Different actions can be setup as 
responses to each type of priority. For example, with 
high priority, a message can immediately pop-up on the io 
display screen and a beep can be caused to occur. With 
a minimum priority, no message pop up occurs, but the 
mobile device can be caused to emit a beep. With low 
priority, a light or symbol can be caused to flash. With no 
priority, no notification is perfomied. is 
[0079] Following the display 608 of the notification 
message or following the decision 606 when the dis- 
playing 608 is bypassed, a determination is made 610 
as to whether a status alert message is to be viewed. 
When the determination is made 610 that a request to 20 
view the status alert message has not been received, 
another determination is made 61 2 as to whether a quit 
has been requested. When a termination request is 
received, the application notify processing operation 
600 ends. Alternatively, when a termination request has 25 
not been received, the application notify processing 
operation 600 repeats as illustrated in Figure 6A. On the 
other hand, when the decision 610 determines there 
has been a request to view the status alert message, 
the status alert message is displayed 614. Thereafter, 30 
the application notify processing 600 can prepare and 
send a reply message to the sender. The processing 
used to prepare and send a replay message can be 
similar to the blocks 308-318 of Figure 3A. 
[0080] As an example of a representative graphical 35 
user interface for the application notify processing oper- 
ation 600, Figures 6B and 6C illustrate representative 
screen displays that can appear on the display screen of 
the mobile device and which are related to receiving 
status alerts. Rgure 6B illustrates a representative high 40 
priority notification message screen display 620. Here, 
the user of the mobile device having the screen display 
620 displayed on its display screen has "Bill Jobs" as an 
associate and requested a high priority alert when "Bill 
Jobs" comes on-line. The high priority notification mes- 4S 
sage pops up on the display screen to immediately 
notify the user of the mobile device. In this example, the 
high priority notification message screen display 620 
includes a message statement 622 ("Bill Jobs is on- 
line"), a time stamp 624 indicating when "Bill Jobs" so 
came on-line, and a phone number 626 for "Bill Jobs". 
The screen display 620 also provides an "OK" softkey 
628 and a "Call" softkey 630 which enables the user to 
send either a text or voice message to the associate that 
is the subject of the alert. 55 
[0081] Figure 6C illustrates a representative alert 
inbox screen display 632 having a brief alert message 
634. The brief alert message 634 indicates that "Bill 



Jobs" is on-line. The alert inbox screen display 632 is 
displayed on the display screen when the inbox is 
selected. The screen display 620 also provides an "OK" 
softkey 628, which enables the user to receive more 
details (such as the screen display 620) pertaining to 
the alert or to send either a text or voice message to the 
selected associate. 

[0082] Figure 6D is a flow diagram of message read 
and reply processing operation 650 according to one 
embodiment of the invention. Message read and reply 
processing operation 650 is performed by a mobile 
devk:e upon receiving an Incoming text message. Mes- 
sage read and reply processing operation 650 begins 
with a decision 652 as to whether a text message has 
been received. In effect, decision 652 causes message 
read and reply processing 650 to be invoked once a text 
message has been received. After receiving the text 
message, the text message Is displayed 654. As an 
example, many mobile devices have an inbox for receiv- 
ing incoming text messages. Hence, the text message 
can be stored in the inbox for subsequent retrieval by a 
user of the mobile device. Once the text message is 
retrieved from the inbox, it is displayed on the display 
screen of the mobile device. 

[0083] After the text message has been displayed, 
message read and reply processing operation 650 
determines at decision 656 whether a user input has 
been received. If no user input has been received, deci- 
sion 656 causes message read and reply processing 
650 to await user input. Once user input has been 
received, a determination is made 658 as to whether the 
user Input is a voice call request. When a determination 
is made 658 that the user Input is a voice call request, a 
call is placed 660 to the sender. Here, the recipient of 
the text message is able to efficiently place a call to the 
sender of the text message to provide a response to the 
message during the votee call. After the call has been 
placed to the sender, message read and reply process- 
ing operation 650 is complete and ends. 
[0084] Alternatively, when the determination is 
made 658 that the user input is not a voice call request, 
another detennination is made 662 as to whether the 
user input is a text message request. When the determi- 
nation is made 662 that the user input Is a text message 
request, a reply message is prepared and sent 664. 
After the reply message has been sent, the message 
read and reply processing operation 650 is complete 
and ends. 

[0085] When the user input is neither a voice call 
request, or a text message request a detennination is 
made 666 as to whether the user input is a termination 
request When the user input is a termination request, 
message read and reply processing operation 650 Is 
complete and ends. Alternatively, when the user input is 
not a termination request, the message read and reply 
processing operation 650 repeats the decision 656 and 
subsequent processing stages. 
[0086] FIG. 6E illustrates a representative text mes- 
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sage screen display 670 that is displayed on the display 
scree : of the mobile device. Text message screen dis- 
play 670 includes a sender designation 672, a message 
body 674 and a telephone number indicator 676 for the 
sender. Here, the message body 674 contains a ques- 5 
tion for the recipient - "Want to have lunch?". The user 
of the mobile device that has received the incoming text 
message can then either directly call the sender using a 
"Call" softkey 678. or prepare and send a reply text 
message using a "Reply" softkey 680. When the user of 10 
the mobile device selects the "Reply" softkey 680, a 
screen display 682 is presented on the display screen of 
the mobile device. The screen display 682 is a reply text 
entry screen that enables the user of the mobile device 
to enter a reply text message. Screen display 682 also 75 
includes a "Send" softkey 684, which enables the user 
to send the reply message to the sender of the original 
text message. 

[0087] Figure 7 A is a flow diagram of privacy set- 
tings processing operation 700 according to one 20 
embodiment of the invention. Privacy settings process- 
ing operation700 begins with a determination 702 as to 
whether a privacy adjustment Is requested. When the 
determination is made 702 that a privacy adjustment Is 
requested, privacy setting processing operation 700 is 25 
initialized; otherwise, the privacy settings processing 
operation 700 is bypassed. For example, the user of a 
mobile device could use the this operation to limit or 
prevent status monitoring of their mobile device. 
[0088] Once privacy setting processing operation 30 
700 is initialized, a list of privacy settings are displayed 
704. For example, the list of privacy settings is displayed 
on a display screen of the mobile device. Next, one of 
the privacy settings is selected 706. Here, a user of the 
mobile device views the list of privacy settings being dis- 35 
played 704 and selects one of the prh^cy settings to be 
utilized with respect to the mobile device. Then, a pri- 
vacy Indicator for the subscriber Is set 708 based on the 
selected privacy setting. Here, the privacy indicator for 
the user (subscriber) is stored in a database (e.g., asso- 40 
ciate mapping data store 284 of database storage 280] 
for subsequent retrieval. For example, the database 
storage can be database storage 1 12 Illustrated in Fig- 
ure 1A or database 280 Illustrated in Figure 2D. After 
the privacy indicator for the subscriber is set 708, the 45 
privacy settings processing operation 700 is complete 
and ends. 

[0089] As an example of a representative graphical 
user interface for privacy settings processing operation 
700, Rgure 7B Illustrates representative screen dis- so 
plays presenting a associates list and setting of alert pri- 
orities. Initially, a screen display 750 having an 
associates list 751 is displayed. Here, presumably, the 
user of the mobile device having screen display 750 dis- 
played on its display screen has 'Bill Jobs", "Steve ss 
Gates" and "John Doe" as associates. These three 
associates are contained within associates list 751. 
Screen display 750 also Includes a selection Indteator 



762 indicating the particular one of the entries being 
selected. In this example, the first entry ("Bill Jobs") is 
selected. The screen display 750 also displays activa- 
tion status Indicators 755. 756 and 757. The activation 
status indicators for each of the entries of associates list 
751 are generated based on the status Infonnation. The 
status indicator 756 displayed adjacent "Steve Gates" 
indicates that associate "Steve Gates" has his mobile 
device active (or on-line) as of the last monitoring cycle. 
The status indicators (755 and 757) displayed adjacent 
to associates "Bill Jobs" and "John Doe" respectively, 
provides an indication that these associates have their 
devices inactive (or off-line) as of the most recent moni- 
toring cycle. Screen display 750 also provides a "Talk" 
softkey 756 which enables a user to send either a text or 
voice message to the selected associate, and a "Menu" 
softkey 758 which enable the user to refresh the display 
screen with a Menu screen display offering the user 
additional choices. Additionally, indicator 754 provides 
an indication to the user that a change of status alert 
has been set for associate "Steve Gates". 
[0090] Upon user selection of the "Menu" softkey 
758 where the selected associate is "Bill Jobs", a 
screen display 760 is presented on the display screen. 
The screen display 760 indicates a list of menu items 
available to the user, namely, Alerts, Privacy, and Add 
Associate operations. Screen display 760 also includes 
a select indicator 762 Indicating the particular one of the 
entries (operations) being selected. In this example, the 
first entry ("Alerts") is selected. Screen display 760 also 
provides an "OK" softkey 764 to invoke the selected 
entry (operation). 

[0091] Upon user selection of the "OK" softkey 764 
with the "Alerts" being selected, a screen display 766 is 
presented on the display screen. Screen display 766 
indicates a list of alert types available to the user, 
namely, high, medium, low and none. Screen displ^ 
766 also includes a select Indicator 768 Indicating the 
particular one of the alert types being selected. In this 
example, the first alert type ("High") is selected. The 
screen display 766 also provides an "OK" softkey 764 to 
invoke the selected alert type. 

[0092] Additionally, the user of a monitored mobile 
device can choose to have their status Inforrnation aug- 
mented with user supplied information. For example, 
the user can Input a text string such as "I am in a meet- 
ing" or "I am busy" or "I am available" or an iconic sym- 
bol with a well-known or predefined meaning. This 
information is combined with the network status infor- 
mation (e.g. active or inactive) to provide a near real- 
time indication of a monitored user's status and availa- 
bility for exchanging messages. 

[0093] The associates list may be associated with 
or used in conjunction with applications resident within 
the mobile device. Address book applications, calendar 
applications and email applications are examples of 
such applications. For example, the associates list 
could be generated from a users address book or local 
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contact list. Changes to the address book would be 
reflected in the associates list and the user would not be 
required to make duplicate entries. One of ordinary skill 
in the art would understand that the process is also 
applicable to network applications (e.g. an address 5 
book resident on a network server but managed from 
the mobile device). 

[0094] Figure 8 is a flow diagram of an address 
book processing operation 800 according to one 
embodiment of the Invention. Address book processing 10 
operation 800 is, for example, performed by a client-side 
apprication for the wireless communication devtee. The 
address book processing operation 800 need not be 
performed by a network browser operable on the mobile 
device, but can be a stand alone application or embed- is 
ded within another functional application, such as an 
address book application. 

[0095] The address book processing operation 800 
initially activates an address book 802. Here, the 
address book is displayed on a display screen of the 20 
mobile device. The address book, for example, includes 
names and telephone numbers for people or busi- 
nesses. The address book (or phone book) can also 
include addresses for the people or the businesses. The 
people or businesses within the address book may be 25 
refen^ed to as contacts. The address book is provided by 
an address book application that executes on the 
mobile device. 

[0096] Next, status information for the contacts in 
the address book is obtained 804. As an example, the 30 
status infomnation can be obtained from a server and 
database such as the server 110 and associate status 
server 112 illustrated in Figure 1 A. Next, contacts in the 
address book are displayed 806 with the associated sta- 
tus infonmation. By displaying the status infonnation 35 
associated with the contacts, the user of the mobile 
device using the address book can determine whether 
communication devices (and perhaps what communica- 
tion devk^es if any), are in use (active) by their contacts 
listed in the address book. 4o 
[0097] Next the user Is queried 808 as to whether 
the user desires to initiate communk;ations with one of 
the contacts in the address book. When a determination 
is made 808 that the user does desire to initiate commu- 
nications with one of the contacts in the address book, 45 
another determination is made 810 as to whether the 
message to be sent is a text message or a voice call. 
When the determination is made 810 that the message 
to be sent is a voice call, a call to the selected contact is 
placed 812. On the other hand, when the determination so 
is made 81 0 that the message to be sent is a text mes- 
sage, the text message is provided 814. For example, 
the text message can be provided by data entry from a 
user of the mobile device. Next, the text message is sent 
81 6 to the selected contact. After the text message has ss 
been sent 81 6 or after the call to the selected contact is 
placed 812, address book processing operation 800 is 
complete and the routine ends. 



[0098] Alternatively, when a determination is made 
808 that a message (text or voice) is not to be sent (i.e., 
a communications is not to be initiated), another deter- 
mination is made 818 as to whether a termination 
request has been received. When a determination is 
made 81 8 that a termination request has been received, 
address book processing operation 800 Is complete and 
ends. On the other hand, when the a determination is 
made 818 that a termination request has not been 
, received, then address book processing operation BOO 
returns to repeat the decision 808 and subsequent 
blocks. 

[0099] In accordance with the principles of the 
present invention, status information relating to one or 
more monitored devices is presented to the user of a 
monitoring mobile device. In one embodiment, the sta- 
tus information includes a status indicator (e.g. a sym- 
bol or icon) which provides an indication of the 
operational status (e.g. on or off) of a monitored device. 
Generally, a remote mobile device is active if it is able to 
receive messages (e.g., voice calls or text messages). 
In the case of a cellular phone, acth^e means that the 
cellular phone is turned on and within range of a sup- 
porting wireless network carrier. On the other hand, 
inactive may mean that the cellular phone is either 
turned off or not in contact with the wireless network 
providing service. Note that due to various possible net- 
work and system delays, the status information 
obtained may not actually reflect the cun'ent status of 
monitored devices. Thus, the status information reflects 
the status of the monitored mobile device as was indi- 
cated during the most recent monitoring cycle for which 
infonmation could be obtained. 

[01 00] Note that while Figures 40 and 7B use a par- 
ticular symbol for the status indicator, any suitable sym- 
bol or other visual indication may be used. Other 
indicators, symbols, alphanumeric characters, icons, or 
other visually distinct objects may be used to indicate 
the status of remote devices. The status infonmation can 
also be more specific in terms of the infonnation con- 
veyed by using one or more status indicators. Namely, 
status indicators could indicate that the associated 
mobile device is active, was recently active, not active or 
has an unknown activation status. The status. indicators 
could also indicate whether the mobile device is in use 
or out of range. Also, in the case where the monitored 
status information Is unknown, such an indication could 
be displayed. Additionally, the status identifier or an 
additional identifier or symbol can be provided to indi- 
cate whether the telephone nunrtber associated with the 
remote device corresponding to a contact is for a land- 
based phone or a wireless phone. Still further, the sta- 
tus indicators could vary as a function of the type of 
communications device. 

[0101] The invention can take the form of a compu- 
ter readable code on a computer readable medium (i.e. 
a substrate). The computer readable medium is a data 
storage device that can store data, which can thereafter, 
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be read by a computer system. Examples of a computer 
readable medium include read-only memory, random- 
access memory, CD-ROMs, magnetic tape, optical data 
storage devices and carrier waves. The computer read- 
able medium can be distributed over a network coupled 
computer system so that the computer readable code is 
stored and executed in a distributed fashion. 
[0102] The advantages of the invention are numer- 
ous. Different embodiments or implementations may 
yield one or more of the following advantages. One 
advantage of the invention Is that users can be visually 
Informed of status information pertaining to other com- 
munication devices, even wireless communication 
devices. Another advantage of the invention is that user 
are able to send, receive and reply to test messages 
with associates on wireless communication devices 
with great ease. Still another potential advantage of the 
invention Is that status alerts can be provided when 
friends or associates come on-line with their wireless 
communication devices. Yet another advantage of the 
invention is a privacy control mechanism that allows 
users to control the dissemination of their status infor- 
mation. Yet another advantage of the invention is that 
wired communications devices, even desktop comput- 
ers, can utilize the features of the invention. 
[0103] The many features and advantages of the 
present invention are apparent from the written descrip- 
tion, and thus, it is intended by the appended claims to 
cover all such features and advantages of the Invention. 
Further, since numerous modifications and changes will 
readily occur to those skilled in the art, it is not desired 
to limit the Invention to the ^act construction and oper- 
ation as illustrated and described. Hence, all suitable 
modifications and equivalents may be considered to fali 
within the scope of the Invention. 

Claims 

1, A method of providing status information to a wire- 
less communication device for a piurailty of mobile 
device, the method comprislng:- 

retrieving status information for the plurality of 

designated mobile devices; 

generating a file containing identifiers for the 

plurality of designated mobile devices and the 

retrieved status Information; and 

forwarding the generated file to the wireless 

communication device. 

2. A method as recited in claim 1 further comprising:- 

omitting status information for those mobile 
devices among the plurality of designated 
mobile devices for which an associated user 
provides an indication that status infomnation 
should not be released to third parties; and 
omitting status Information for those mobile 



devtoes among the plurality of designated 
mobile devices when an associated user has 
not provided an indication that status infomia- 
tlon may be released to third parties. 

5 

3. A method as recited in claim 1 or 2 further compris- 
ing:- 

requesting access rights for status infomnation 
10 from those mobile devices among the plurality 

of designated mobile devices for which the 
wireless client device does not have access 
rights; 

receiving a request for status information mon- 
is itoring, the request including identifiers for the 

one or more mobile devices to be monitored. 

4. A method as recited in any preceding claim further 
comprising: - 

20 

foravarding the generated file to one or more of 
the plurality of designated mobile devices. 

5. A method as recited in any preceding claim further 
25 comprising: - 

fonvarding tiie generated file to a designated 
communication device. 

30 6, A method for interacting with a wireless communi- 
cation device having a display screen and user 
interface, the method comprising:- 

retrieving status information for a plurality of 
35 previously identified mobile devices at pre- 

determined intervals; 

generating a list including a representation of 
the retrieved status information and an Identi- 
fier for each of the plurality of previously identi- 
40 fled mobile devices; and 

forwarding the list to the wireless communica- 
tion device. 

7. A method as recited in claim 6 wherein the repre- 
45 sentation of the retrieved status Infomnation is an 
alphanumeric string and wherein the representa- 
tion of the retrieved status Information is a symbolic 
Indbator. 

50 8. A method as recited in claim 6 or 7 further compris- 
ing:- 

obtaining identifiers for designated communi- 
cation devices that are to receive the list; and 
55 fonvarding the list to the designated devices. 

9. A computer product executable by a computing 
device, the computer product including computer 
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program code for providing status information on 
the display screen of a wireless communication 
device, the computer product comprising:- 



computer program code for retrieving a list con- s 
taining status information for a plurality of previ- 
ously Identified mobile devices; and 
computer program code for displaying the list 
containing identifiers and status infonnation for 
the plurality of previously identified mobile io 
devices on the display screen of the wireless 
communication device. 



10. A computer product executable by a computing 

device, the computer product Including computer is 
program code for providing status information on 
the display screen of a wireless communication 
device, the computer product comprising:- 

computer program code for establishing an 20 
alert request relating to changes in device sta- 
tus for one or more mobile devices among a 
plurality of previously identified mobile devices; 
and 

computer program code for receiving an alert in 2S 
accordance with the alert request when one or 
more of the previously identified mobile devices 
Is indicated as having an altered status. 

11« A computer product as recited in claim 10 further 30 
comprising:- 

computer program code for determining 
whether the alert priority exceeds a predeter- 
mined priority level; and 35 
computer program code for immediately dis- 
playing a notification message informing of sta- 
tus change that triggered the alert when the 
alert priority is greater than the predetermined 
priority level. 40 

12. A wireless communication device having a display 
screen and user interface, the device comprising:- 

a storage device for storing a list containing 4S 
status information and identifiers for a plurality 
of previously identified mobile devices; 
a memory for storing program code for a proc- 
essor; and 

a processor coupled to said storage device and so 
said memory, wherein the processor operates 
to execute the program code stored In the 
memory to retrieve and store a list containing 
status information and identifiers for a plurality 
of previously identified mobile devices from a ss 
remote server device and display it on the dis- 
play screen of the wireless communication 
device. 
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